<template>
  <div class="login-title">
    <h2 class="title">管理后台</h2>
  </div>
  <el-form ref="ruleFormRef" :model="ruleForm" :rules="rules">
    <el-form-item label="" prop="username">
      <el-input placeholder="请输入用户名" autoComplete="on" style="position: relative" v-model="ruleForm.username"
        @keyup.enter.native="submitForm(ruleFormRef)">
        <template #prefix>
          <el-icon class="el-input__icon">
            <UserFilled />
          </el-icon>
        </template>
      </el-input>
    </el-form-item>

    <el-form-item label="" prop="password">
      <el-input placeholder="请输入密码" autoComplete="on" @keyup.enter.native="submitForm(ruleFormRef)"
        v-model="ruleForm.password" :type="passwordType">
        <template #prefix>
          <el-icon class="el-input__icon">
            <GoodsFilled />
          </el-icon>
        </template>
        <template #suffix>
          <div class="show-pwd" @click="showPwd">
            <svg-icon :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'" />
          </div>
        </template>
      </el-input>
    </el-form-item>

    <el-form-item style="width: 100%">
      <el-button :loading="loading" class="login-btn" type="primary" @click="submitForm(ruleFormRef)">登录</el-button>
    </el-form-item>
  </el-form>
</template>
<script lang="ts" setup>
import { ref, reactive, onMounted } from 'vue'
import type { FormInstance } from 'element-plus'
import { ElNotification } from "element-plus";
import { useRouter } from 'vue-router'
import { useUserStore } from "@/store/modules/user"
import { getTimeStateStr } from '@/utils/index'
import { Logger } from '@/engine/util/Logger';
import { UIHelper } from '@/utils/UIHelper';
import { UserModel } from '@/store/model/UserModel';
import { HttpClient } from '@/utils/HttpClient';

const router = useRouter()
const UserStore = useUserStore()
const ruleFormRef = ref<FormInstance>()
const passwordType = ref('password')
const loading = ref(false)

const rules = reactive({
  password: [{ required: true, message: "请输入用户名", trigger: "blur" }],
  username: [{ required: true, message: "请输入密码", trigger: "blur" }],
})

// 表单数据
const ruleForm = reactive({
  username: '',
  password: '',
})

// 显示密码图标
const showPwd = () => {
  passwordType.value = passwordType.value === 'password' ? '' : 'password'
}

const submitForm = (formEl: FormInstance | undefined) => {

  Logger.log("submitForm===", ruleForm)
  if (ruleForm.username == "") {
    UIHelper.showMsg("请输入用户名")
    return;
  }
  if (ruleForm.password == "") {
    UIHelper.showMsg("请输入密码")
    return;
  }
  HttpClient.login(ruleForm.username, ruleForm.password, () => {
    router.push({
      path: '/',
    })
  })

  // UIHelper.showMsg("abcd")
  // router.push({
  //   path: '/',
  // })
  // if (!formEl) return
  // formEl.validate((valid) => {
  //   if (valid) {
  //     loading.value = true
  //     // 登录
  //     setTimeout(async ()=>{
  // await UserStore.login(ruleForm)
  // await router.push({
  //   path: '/',
  // })
  //       ElNotification({
  //         title: getTimeStateStr(),
  //         message: "欢迎登录 Vue Admin Perfect",
  //         type: "success",
  //         duration: 3000
  //       });
  //       loading.value = true
  //     },1000)
  //   } else {
  //     console.log('error submit!')
  //     return false
  //   }
  // })
}

onMounted(() => {
  ruleForm.username = UserModel.instance.userName
  ruleForm.password = UserModel.instance.pass
})
</script>

<style lang="scss" scoped>
@import "../index.scss";
</style>
